package interfaz;

import clases.ClsDatabase;
import clases.ClsException;
import clases.ClsMetodos;
import clases.ClsProyectoSQL;
import clases.ClsSesion;
import clases.ClsTabla;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import javax.swing.JOptionPane;
import javax.swing.table.DefaultTableModel;

/**
 *
 * @author MK
 */
public class dlgProyectos extends javax.swing.JDialog {

    private ClsMetodos metodos = new ClsMetodos();
    private ClsDatabase bd = new ClsDatabase();
    private ClsTabla clsTabla = new ClsTabla();
    private ClsProyectoSQL clsproyectoSQL = new ClsProyectoSQL();

    /**
     * Creates new form dlgProyectos
     *
     * @param parent
     * @param modal
     */
    public dlgProyectos(java.awt.Frame parent, boolean modal) {
        super(parent, modal);
        initComponents();
//        clsproyectoSQL=new ClsProyectoSQL(parent);
        _iniciar();
    }

    public final void _iniciar() {
        setLocation(5, 76);
        metodos._iconJDialog(this);
        metodos.tablaOcultarcolumnas(tblProyectos, new int[]{0});
        metodos.tablaLongitudColumnas(tblProyectos, new int[]{0, 400, 200, 80});
        txtBuscar.setText("");
        txtBuscar.requestFocus();
        _cargarTabla();
    }
//___________________________________________________________________________________ Soy una barra separadora :)
    //<editor-fold desc="name">

    public void _cargarTabla() {
        String nombreBuscar = txtBuscar.getText().toString();
        metodos.tablaLlenaSql_defecto(tblProyectos,
                "idproyecto,nombre,lugar,DATE_FORMAT(fecha_registro,'%d-%m-%Y'),idusuario",
                "FROM proyecto "
                + "WHERE nombre like '%" + nombreBuscar + "%' "
                + "ORDER BY idproyecto");
    }

    public boolean tablaLlenaSql(javax.swing.JTable table, String camposSelect, String sqlFromWhere) {
        DefaultTableModel mdt = (DefaultTableModel) table.getModel();
        metodos.tablaLimpia(mdt);
        boolean va = true;
        String sql = "SELECT " + camposSelect + " " + sqlFromWhere;
        int n = 0;
        try {
            bd.getConnection();
            PreparedStatement pstm = bd.conn.prepareStatement(sql);
            ResultSet res = pstm.executeQuery();
            String colname[] = camposSelect.split(",");
            n = colname.length;

            while (res.next()) {
                Object mat[] = new Object[n];
                for (int i = 0; i < n; i++) {
                    if (i == 4) {
//                        System.err.println(i+"...."+res.getString(5).toString());
                        if (res.getString(5).toString().equals("0")) {
                            mat[i] = "Plantilla";
                        } else if (res.getString(5).toString().equals("1")) {
                            mat[i] = "Normal";
                        }
                    } else {
                        mat[i] = res.getString(i + 1);
                    }
                }
//                mat[n]=0;
                mdt.addRow(mat);
            }
            res.close();
        } catch (Exception e) {
            System.err.println("sql: " + e);
            e.printStackTrace();
            ClsException._exceptionWriteFile(e);
        }
        //clsTabla.packColumn(table, 4, 2);
        System.out.println("tablaLlenaSql--> " + sql);
        return va;
    }

    public void Eliminar() {
        int fila = tblProyectos.getSelectedRow();//Obtenemos la fila seleccionada
        if (fila != -1) {
            //Confirmamos la eliminacion
            if (JOptionPane.showConfirmDialog(null, "Está seguro que desea eliminar el Proyecto seleccionado", "Mensaje", JOptionPane.YES_NO_OPTION, JOptionPane.QUESTION_MESSAGE) == 0) {
                String id = tblProyectos.getValueAt(fila, 0).toString();
                boolean seRepite = bd.verif_repite("SELECT idproyecto FROM presupuesto WHERE idproyecto='" + id + "'");
                if (!seRepite) {
                    boolean seElimino = bd.delete("proyecto", "idproyecto='" + id + "'");
                    if (seElimino) {
                        _cargarTabla();
                        // JOptionPane.showMessageDialog(null, "Se elimino el proyecto con exito");
                    }
                } else {
                    JOptionPane.showMessageDialog(null, "No se puede eliminar este proyecto, esta siendo usado!!!");
                }
            }
        } else {
            JOptionPane.showMessageDialog(null, "Seleccione el proyecto!");
        }
    }

    //</editor-fold>
//___________________________________________________________________________________ Soy una barra separadora :)
    //<editor-fold desc="name">
    //</editor-fold>
//___________________________________________________________________________________ Soy una barra separadora :)
    public void seleccion_presupuesto() {
        int fila = tblProyectos.getSelectedRow();
        if (fila != -1) {
            String id_proyecto = tblProyectos.getValueAt(fila, 0).toString();
            String nombre = tblProyectos.getValueAt(fila, 1).toString();

            new dlg_presupuesto_prototipo(new javax.swing.JFrame(), true, id_proyecto, nombre).setVisible(true);
        } else {
            JOptionPane.showMessageDialog(null, "Seleccione un Proyecto");
        }
    }

    @SuppressWarnings("unchecked")
    // <editor-fold defaultstate="collapsed" desc="Generated Code">//GEN-BEGIN:initComponents
    private void initComponents() {

        fondo = new javax.swing.JPanel();
        jScrollPane1 = new javax.swing.JScrollPane();
        tblProyectos = new javax.swing.JTable();
        jPanel1 = new javax.swing.JPanel();
        jLabel2 = new javax.swing.JLabel();
        txtBuscar = new javax.swing.JTextField();
        jLabel10 = new javax.swing.JLabel();
        btnNuevo = new javax.swing.JButton();
        btnEditar = new javax.swing.JButton();
        btnDuplicar = new javax.swing.JButton();
        btnPresupuesto = new javax.swing.JButton();
        jButton1 = new javax.swing.JButton();
        btnEliminar1 = new javax.swing.JButton();

        setDefaultCloseOperation(javax.swing.WindowConstants.DISPOSE_ON_CLOSE);
        setTitle("Proyectos");

        fondo.setBackground(new java.awt.Color(225, 235, 247));
        fondo.setMaximumSize(new java.awt.Dimension(32767, 598));
        fondo.setMinimumSize(new java.awt.Dimension(100, 590));
        fondo.setLayout(new org.netbeans.lib.awtextra.AbsoluteLayout());

        tblProyectos.setModel(new javax.swing.table.DefaultTableModel(
            new Object [][] {
                {null, null, null, null},
                {null, null, null, null},
                {null, null, null, null},
                {null, null, null, null}
            },
            new String [] {
                "ID", "Nombre del Proyecto ", "Ubicación", "Fecha "
            }
        ) {
            boolean[] canEdit = new boolean [] {
                false, false, false, false
            };

            public boolean isCellEditable(int rowIndex, int columnIndex) {
                return canEdit [columnIndex];
            }
        });
        tblProyectos.setSelectionMode(javax.swing.ListSelectionModel.SINGLE_SELECTION);
        tblProyectos.addMouseListener(new java.awt.event.MouseAdapter() {
            public void mouseClicked(java.awt.event.MouseEvent evt) {
                tblProyectosMouseClicked(evt);
            }
        });
        jScrollPane1.setViewportView(tblProyectos);

        fondo.add(jScrollPane1, new org.netbeans.lib.awtextra.AbsoluteConstraints(10, 88, 857, 330));

        jPanel1.setBorder(javax.swing.BorderFactory.createTitledBorder("Buscar"));
        jPanel1.setOpaque(false);
        jPanel1.setLayout(new org.netbeans.lib.awtextra.AbsoluteLayout());

        jLabel2.setHorizontalAlignment(javax.swing.SwingConstants.CENTER);
        jLabel2.setText("Proyecto:");
        jPanel1.add(jLabel2, new org.netbeans.lib.awtextra.AbsoluteConstraints(20, 25, -1, 20));

        txtBuscar.addKeyListener(new java.awt.event.KeyAdapter() {
            public void keyReleased(java.awt.event.KeyEvent evt) {
                txtBuscarKeyReleased(evt);
            }
        });
        jPanel1.add(txtBuscar, new org.netbeans.lib.awtextra.AbsoluteConstraints(80, 25, 351, 23));

        fondo.add(jPanel1, new org.netbeans.lib.awtextra.AbsoluteConstraints(10, 10, 850, 60));

        jLabel10.setIcon(new javax.swing.ImageIcon(getClass().getResource("/resource/icon/principales/fondo_dialog.jpg"))); // NOI18N
        fondo.add(jLabel10, new org.netbeans.lib.awtextra.AbsoluteConstraints(0, 0, 450, 330));

        btnNuevo.setForeground(new java.awt.Color(3, 90, 180));
        btnNuevo.setIcon(new javax.swing.ImageIcon(getClass().getResource("/resource/icon/principales/peque/agregar.png"))); // NOI18N
        btnNuevo.setText("Nuevo");
        btnNuevo.setFocusable(false);
        btnNuevo.setHorizontalTextPosition(javax.swing.SwingConstants.RIGHT);
        btnNuevo.addActionListener(new java.awt.event.ActionListener() {
            public void actionPerformed(java.awt.event.ActionEvent evt) {
                btnNuevoActionPerformed(evt);
            }
        });
        fondo.add(btnNuevo, new org.netbeans.lib.awtextra.AbsoluteConstraints(10, 450, 95, -1));

        btnEditar.setForeground(new java.awt.Color(3, 90, 180));
        btnEditar.setIcon(new javax.swing.ImageIcon(getClass().getResource("/resource/icon/principales/peque/editar.png"))); // NOI18N
        btnEditar.setText("Editar");
        btnEditar.setFocusable(false);
        btnEditar.setHorizontalTextPosition(javax.swing.SwingConstants.RIGHT);
        btnEditar.addActionListener(new java.awt.event.ActionListener() {
            public void actionPerformed(java.awt.event.ActionEvent evt) {
                btnEditarActionPerformed(evt);
            }
        });
        fondo.add(btnEditar, new org.netbeans.lib.awtextra.AbsoluteConstraints(110, 450, 95, -1));

        btnDuplicar.setForeground(new java.awt.Color(3, 90, 180));
        btnDuplicar.setIcon(new javax.swing.ImageIcon(getClass().getResource("/resource/icon/principales/peque/duplicar.png"))); // NOI18N
        btnDuplicar.setText("Duplicar");
        btnDuplicar.setFocusable(false);
        btnDuplicar.setHorizontalTextPosition(javax.swing.SwingConstants.RIGHT);
        btnDuplicar.addActionListener(new java.awt.event.ActionListener() {
            public void actionPerformed(java.awt.event.ActionEvent evt) {
                btnDuplicarActionPerformed(evt);
            }
        });
        fondo.add(btnDuplicar, new org.netbeans.lib.awtextra.AbsoluteConstraints(325, 450, 110, -1));

        btnPresupuesto.setForeground(new java.awt.Color(3, 90, 180));
        btnPresupuesto.setIcon(new javax.swing.ImageIcon(getClass().getResource("/resource/icon/principales/peque/presupuesto_tool.png"))); // NOI18N
        btnPresupuesto.setText("Presupuesto");
        btnPresupuesto.setFocusable(false);
        btnPresupuesto.setHorizontalTextPosition(javax.swing.SwingConstants.RIGHT);
        btnPresupuesto.addActionListener(new java.awt.event.ActionListener() {
            public void actionPerformed(java.awt.event.ActionEvent evt) {
                btnPresupuestoActionPerformed(evt);
            }
        });
        fondo.add(btnPresupuesto, new org.netbeans.lib.awtextra.AbsoluteConstraints(440, 450, -1, -1));

        jButton1.setIcon(new javax.swing.ImageIcon(getClass().getResource("/resource/icon/principales/peque/salir.png"))); // NOI18N
        jButton1.setText("Salir");
        jButton1.addActionListener(new java.awt.event.ActionListener() {
            public void actionPerformed(java.awt.event.ActionEvent evt) {
                jButton1ActionPerformed(evt);
            }
        });
        fondo.add(jButton1, new org.netbeans.lib.awtextra.AbsoluteConstraints(760, 450, 102, -1));

        btnEliminar1.setForeground(new java.awt.Color(3, 90, 180));
        btnEliminar1.setIcon(new javax.swing.ImageIcon(getClass().getResource("/resource/icon/principales/peque/eliminar.png"))); // NOI18N
        btnEliminar1.setText("Eliminar");
        btnEliminar1.setFocusable(false);
        btnEliminar1.setHorizontalTextPosition(javax.swing.SwingConstants.RIGHT);
        btnEliminar1.addActionListener(new java.awt.event.ActionListener() {
            public void actionPerformed(java.awt.event.ActionEvent evt) {
                btnEliminar1ActionPerformed(evt);
            }
        });
        fondo.add(btnEliminar1, new org.netbeans.lib.awtextra.AbsoluteConstraints(210, 450, 110, -1));

        javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
        getContentPane().setLayout(layout);
        layout.setHorizontalGroup(
            layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addComponent(fondo, javax.swing.GroupLayout.DEFAULT_SIZE, 900, Short.MAX_VALUE)
        );
        layout.setVerticalGroup(
            layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addComponent(fondo, javax.swing.GroupLayout.PREFERRED_SIZE, 506, javax.swing.GroupLayout.PREFERRED_SIZE)
        );

        pack();
    }// </editor-fold>//GEN-END:initComponents

    private void btnNuevoActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btnNuevoActionPerformed
        dlg_NewProyecto dialog = new dlg_NewProyecto(new javax.swing.JFrame(), true, this, tblProyectos);
        // dialog.setTitle("Agregando nuevo Proyecto");
        dialog.setVisible(true);
    }//GEN-LAST:event_btnNuevoActionPerformed

    private void btnEditarActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btnEditarActionPerformed
        dlg_NewProyecto dialogN = new dlg_NewProyecto(new javax.swing.JFrame(), true, this, tblProyectos);
        //dialogN.setTitle("Editando el Proyecto elegido");
        dialogN.Editar(1);
    }//GEN-LAST:event_btnEditarActionPerformed

    private void btnDuplicarActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btnDuplicarActionPerformed
        dlg_NewProyecto dialogN = new dlg_NewProyecto(new javax.swing.JFrame(), true, this, tblProyectos);
        //dialogN.setTitle("Editando el Proyecto elegido");
        dialogN.Editar(2);
    }//GEN-LAST:event_btnDuplicarActionPerformed

    private void txtBuscarKeyReleased(java.awt.event.KeyEvent evt) {//GEN-FIRST:event_txtBuscarKeyReleased
        _cargarTabla();
    }//GEN-LAST:event_txtBuscarKeyReleased

    private void tblProyectosMouseClicked(java.awt.event.MouseEvent evt) {//GEN-FIRST:event_tblProyectosMouseClicked
        if (evt.getClickCount() == 2) {
            dlg_NewProyecto dialogN = new dlg_NewProyecto(new javax.swing.JFrame(), true, this, this.tblProyectos);
            //dialogN.setTitle("Editando el Proyecto elegido");
            dialogN.Editar(1);
        }
    }//GEN-LAST:event_tblProyectosMouseClicked

    private void btnPresupuestoActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btnPresupuestoActionPerformed
        seleccion_presupuesto();
    }//GEN-LAST:event_btnPresupuestoActionPerformed

    private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_jButton1ActionPerformed
        dispose();
    }//GEN-LAST:event_jButton1ActionPerformed

    private void btnEliminar1ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btnEliminar1ActionPerformed
        Eliminar();
    }//GEN-LAST:event_btnEliminar1ActionPerformed

    /**
     * @param args the command line arguments
     */
    public static void main(String args[]) {
        /* Set the Nimbus look and feel */
        //<editor-fold defaultstate="collapsed" desc=" Look and feel setting code (optional) ">
        /* If Nimbus (introduced in Java SE 6) is not available, stay with the default look and feel.
         * For details see http://download.oracle.com/javase/tutorial/uiswing/lookandfeel/plaf.html 
         */
        try {
            for (javax.swing.UIManager.LookAndFeelInfo info : javax.swing.UIManager.getInstalledLookAndFeels()) {
                if ("Nimbus".equals(info.getName())) {
                    javax.swing.UIManager.setLookAndFeel(info.getClassName());
                    break;
                }
            }
        } catch (ClassNotFoundException ex) {
            java.util.logging.Logger.getLogger(dlgProyectos.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
        } catch (InstantiationException ex) {
            java.util.logging.Logger.getLogger(dlgProyectos.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
        } catch (IllegalAccessException ex) {
            java.util.logging.Logger.getLogger(dlgProyectos.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
        } catch (javax.swing.UnsupportedLookAndFeelException ex) {
            java.util.logging.Logger.getLogger(dlgProyectos.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
        }
        //</editor-fold>

        /* Create and display the dialog */
        java.awt.EventQueue.invokeLater(new Runnable() {
            public void run() {
                dlgProyectos dialog = new dlgProyectos(new javax.swing.JFrame(), true);
                dialog.addWindowListener(new java.awt.event.WindowAdapter() {
                    @Override
                    public void windowClosing(java.awt.event.WindowEvent e) {
                        System.exit(0);
                    }
                });
                dialog.setVisible(true);
            }
        });
    }
    // Variables declaration - do not modify//GEN-BEGIN:variables
    private javax.swing.JButton btnDuplicar;
    private javax.swing.JButton btnEditar;
    private javax.swing.JButton btnEliminar1;
    private javax.swing.JButton btnNuevo;
    private javax.swing.JButton btnPresupuesto;
    public javax.swing.JPanel fondo;
    private javax.swing.JButton jButton1;
    private javax.swing.JLabel jLabel10;
    private javax.swing.JLabel jLabel2;
    private javax.swing.JPanel jPanel1;
    private javax.swing.JScrollPane jScrollPane1;
    private javax.swing.JTable tblProyectos;
    private javax.swing.JTextField txtBuscar;
    // End of variables declaration//GEN-END:variables
}
